<script setup lang="ts">
import { getMemberAddressAPI } from '@/services/address'
import type { AddressItem } from '@/types/address'
import { onShow } from '@dcloudio/uni-app'
import { onMounted, ref, computed } from 'vue'
import { useAddressStore } from '@/stores'

// 调用父组件 goods.vue 的关闭弹出层方法
const emit = defineEmits<{
  (event: 'close'): void
}>()

// 获取收货列表地址数据
const addressList = ref<AddressItem[]>()
const getMemberAddressData = async () => {
  const res = await getMemberAddressAPI()
  addressList.value = res.result
}

// 初始化的时候调用，这里用
onShow(() => {
  getMemberAddressData()
})

onMounted(() => {
  getMemberAddressData()
})

// 新建收货地址
const onAddAddress = () => {
  uni.navigateTo({ url: '/pagesMember/address-form/address-form' })
}

const addressStore = useAddressStore()

// 当前选中的地址
const selectedAddress = computed(() => {
  return addressStore.selectedAddress || addressList.value?.find((item) => item.isDefault)
})

// 修改收货地址
const onChangeAddress = (item: AddressItem) => {
  // 修改地址
  addressStore.changeSelectedAddress(item)
}
</script>

<template>
  <view class="address-panel">
    <!-- 关闭按钮 -->
    <text class="close icon-close" @tap="emit('close')"></text>
    <!-- 标题 -->
    <view class="title">配送至</view>
    <!-- 内容 -->
    <view class="content">
      <view class="item" v-for="item in addressList" :key="item.id">
        <view class="user">{{ item.receiver }} {{ item.contact }}</view>
        <view class="address">{{ item.fullLocation }} {{ item.address }}</view>
        <text
          class="icon"
          :class="{
            'icon-checked': selectedAddress === item,
            'icon-ring': !(selectedAddress === item)
          }"
          @tap="onChangeAddress(item)"></text>
      </view>
    </view>
    <view class="footer">
      <view class="button secondary" @tap="onAddAddress">新建地址</view>
      <view class="button primary" @tap="emit('close')">确定</view>
    </view>
  </view>
</template>

<style lang="scss">
.address-panel {
  padding: 0 30rpx;
  border-radius: 10rpx 10rpx 0 0;
  position: relative;
  background-color: #fff;
}

.title {
  line-height: 1;
  padding: 40rpx 0;
  text-align: center;
  font-size: 32rpx;
  font-weight: normal;
  border-bottom: 1rpx solid #ddd;
  color: #444;
}

.close {
  position: absolute;
  right: 24rpx;
  top: 24rpx;
}

.content {
  min-height: 300rpx;
  max-height: 540rpx;
  overflow: auto;
  padding: 20rpx;
  .item {
    padding: 30rpx 50rpx 30rpx 60rpx;
    background-size: 40rpx;
    background-repeat: no-repeat;
    background-position: 0 center;
    background-image: url(https://pcapi-xiaotuxian-front-devtest.itheima.net/miniapp/images/locate.png);
    position: relative;
  }
  .icon {
    color: #999;
    font-size: 40rpx;
    transform: translateY(-50%);
    position: absolute;
    top: 50%;
    right: 0;
  }
  .icon-checked {
    color: #27ba9b;
  }
  .icon-ring {
    color: #444;
  }
  .user {
    font-size: 28rpx;
    color: #444;
    font-weight: 500;
  }
  .address {
    font-size: 26rpx;
    color: #666;
  }
}

.footer {
  display: flex;
  justify-content: space-between;
  padding: 20rpx 0 40rpx;
  font-size: 28rpx;
  color: #444;

  .button {
    flex: 1;
    height: 72rpx;
    text-align: center;
    line-height: 72rpx;
    margin: 0 20rpx;
    color: #fff;
    border-radius: 72rpx;
  }

  .primary {
    color: #fff;
    background-color: #27ba9b;
  }

  .secondary {
    background-color: #ffa868;
  }
}
</style>
